java - jSTL中根据索引获取arraylist的元素
全部标签 我有一个散列数组,表示对象作为对API调用的响应。我需要从一些散列中提取数据,一个特定的键用作散列对象的id。我想将数组转换为散列,其中键作为ID,值作为具有该ID的原始散列。我说的是:api_response=[{:id=>1,:foo=>'bar'},{:id=>2,:foo=>'anotherbar'},#..]ideal_response={1=>{:id=>1,:foo=>'bar'},2=>{:id=>2,:foo=>'anotherbar'},#..}我可以想到两种方法。将数据映射到ideal_response(下)使用api_response.find{|x|x[:id
我有这个代码require'mechanize'@agent=Mechanize.newpage=@agent.get('http://something.com/?page=1')next_page=page.link_with(:href=>/^?page=2/).click如您所见,此代码应转到下一页。next_page应该有urlhttp://something.com/?page=2如何获取next_page的当前url? 最佳答案 next_page.uri.to_s参见http://www.rubydoc.info/g
我想提取XML文件的一部分,并记下我提取了该文件中的某些部分,例如“这里提取了一些东西”。我正尝试用Nokogiri来做这件事,但似乎并没有真正记录如何:删除的所有child更改inner_text那个完整的元素有什么线索吗? 最佳答案 Nokogiri让这一切变得非常简单。使用thisdocument例如,以下代码将找到所有vitamins标签,删除它们的子标签(以及子标签的子标签等),并将它们的内部文本更改为“Childrenremoved”。require'nokogiri'io=File.open('sample.xml',
有没有一种干净的方法可以从.gemspec文件中提取版本字符串?(gem尚未安装)例如somethingcool.gemspec是Gem::Specification.newdo|s|s.name="somethingcool"s.version="1.2.3"...etc...end我想提取“1.2.3”。我可以grep出来,但必须有更好的方法。 最佳答案 require"rubygems"spec=Gem::Specification::load("example.gemspec")putsspec.version
在morerubywayofdoingprojecteuler#2,部分代码为while((v=fib(i))有没有办法将i+=1变成更函数式的编程风格结构?我能想到的最好的是Float::MAX.to_i.timesdo|i|v=fib(i)breakunlessv因为您不能对float调用.times。 最佳答案 Numeric.step具有无穷大(极限)和1(步长)的默认参数。1.stepdo|i|#...end为了好玩,你甚至可能想尝试一下1.step.size 关于ruby-使
我知道,在Ruby中,您可以使用Integer#lcm求两个数的最小公倍数的方法。例如:10.lcm(15)#=>30是否有一种有效的(或内置于核心或标准库中)方法来获取给定数组中所有整数的最小公倍数?例如:[5,3,10,2,20].lcm#=>60 最佳答案 任何需要两个操作数的操作都可以通过folding迭代地应用于一个集合它:Enumerable#inject/reduce.为了覆盖空情况,将identityelement作为第一个参数传递操作的最小公分母为1。[5,3,10,2,20].reduce(1){|acc,n|a
我有这样一个字符串:大家好,我叫John(又名Johnator)。获取括号(包括括号)之间的内容的最佳方法是什么? 最佳答案 您可以使用String#[]使用正则表达式:a="HimynameisJohn(akaJohnator)"a[/\(.*?\)/]#=>"(akaJohnator)" 关于ruby-从Ruby中的String对象获取括号之间的内容,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com
如何在发布后在单独的脚本中使用httparty从Rails项目中获取响应url或id?ruby脚本:HTTParty.post('http://localhost:3000/change_logs',parameters)response.body和所有其他的不显示url和响应id 最佳答案 两年后,我找到了一种从response的request属性访问最后一个URI的方法:url="http://example.com/redirects/to/www"response=HTTParty.get(url)response.requ
如何获取代表给定时区中特定日期的一天开始的rubyTime对象。 最佳答案 date=Date.todaydate.to_time.in_time_zone('America/New_York').beginning_of_day当前输出=>2011-11-0200:00:00-0400Time.now.in_time_zone('Asia/Shanghai').beginning_of_day当前输出=>2011-11-0300:00:00+0800date=Date.todaydate.to_time.in_time_zon
我是Ruby的新手,目前正在编写一些练习代码,如下所示:puts'Hellothere,Canyoutellmeyourfavouritenumber?'num=gets.chompputs'Yourfavouritenumberis'+num+'?'puts'Wellitsnotbadbut'+num*10+'isliterally10timesbetter!'然而,这段代码只是放置了num变量的十个副本,实际上并没有乘以这个数字,所以我假设我需要让“num”变量成为一个整数?我在这方面没有成功,所以任何人都可以告诉我哪里出错了吗? 最佳答案